草庐IT

MySQL 查询根据不同条件连接 4 个表

全部标签

ruby - ActiveRecord - 在连接模型中查找具有共享属性的所有对象

我有三个模型classBoat我正在尝试编写一个简单的ActiveRecord查询来查找所有帆船类型的船。类似于Boat.where(classifications:"Sailboat") 最佳答案 我认为这可行:Boat.joins(:classifications).where(classifications:{name:'Sailboat'})#nameorwhateverfieldcontainsSailboat生成此查询:SELECT`boats`.*FROM`boats`INNERJOIN`boat_classifica

ruby-on-rails - Rails STI 和多级继承查询

在我的数据库中,我有一个表people,我正在使用单表继承,这些类:classPerson它生成的查询让我很困惑。我想要的是Member.all返回所有企业以及成员的任何其他子类型。它确实如此,但前提是我最近访问了商务舱。我认为这是因为我的类没有在开发模式下缓存(出于明显的原因),但它仍然看起来像奇怪的/错误的行为。这是Rails中的错误吗?或者它是否按预期工作?在任何一种情况下,任何人都可以想到一个用于开发目的的好的解决方案吗? 最佳答案 这是故意的行为——官方Rails指南AutoloadingandReloadingConst

ruby - 分配分支条件太高

我有一个简单的类,它在初始化时接受一到八个参数。它将访问器设置为这些访问器以供以后使用。Rubocop正试图以ABC太高为由逮捕我,但我不确定我所做的是否真的有任何问题。在这种情况下,我只是在初始化时禁用检查吗?classFooattr_accessor:one,:two,:three,:fourattr_accessor:five,:six,:seven,:eightdefinitialize(p={})@one=p[:one]ifp[:one].present?#...@eight=p[:eight]ifp[:eight].present?endend关于减小大小,我唯一的想法是做

ruby-on-rails - Ruby on Rails - 在 ':include =>' 上添加条件以加载有限数量的对象

我有两个模型用户和事件。基数是一个用户有很多事件。当我查询数据库以提供所有用户及其相应事件时,它会返回正确的结果。示例语句:Users.find(:all,:include=>[:events])但是,我需要帮助的是根据条件为用户获取事件。我需要返回的每个用户只获取今天安排的事件(例如:CREATED_DATE=TODAY)。也就是说,我不希望所有事件都与用户关联。也就是说,我仍然需要在数据库中找到的所有用户,但对于今天没有安排事件的一些用户,他们不应该在HashMap中加载事件。有人可以帮我修改“Users.find(:all,:include=>[:events])”Rails语句

ruby-on-rails - 乘客并发连接错误

我有生产服务器(Nginx+Passenger)。当我尝试从另一台计算机ab-n3-c3myhost.ru/时,我在我的nginxerror.log中收到此错误日志:[pid=21160thr=139775297914624file=ext/nginx/HelperAgent.cpp:584time=2011-08-3115:25:49.22]:UncaughtexceptioninPassengerServerclientthread:exception:Cannotreadresponsefrombackendprocess:Connectionresetbypeer(104)ba

ruby - 你如何理解 Ruby 中的这个三元条件?

我在某些代码中遇到了三元组,但我无法理解条件:str.split(/',\s*'/).mapdo|match|match[0]==?,?match:"somestring"end.join我确实理解我是在某些点上拆分字符串并将总结果转换为数组,然后依次处理数组的每个元素。除此之外,我不知道发生了什么。 最佳答案 一种(稍微)不那么令人困惑的写法是:str.split(/',\s*'/).mapdo|match|ifmatch[0]==?,matchelse"somestring"endend.join我认为多行三元语句很糟糕,尤其是

ruby - Rails 3.2 CRUD : . 其中 'or' 有条件

使用ruby​​onrails,我想做类似的事情:@tasks=Task.where(:def=>true||:house_id=>current_user.house_id)执行此操作的最有效/最干净的方法是什么? 最佳答案 你可以这样做:Task.where("def=?orhouse_id=?",true,current_user.house_id)一般情况是:Model.where("column=?orother_column=?",value,other_value)您还可以利用Arel:t=Task.arel_tabl

ruby-on-rails - ruby 中相同对象值的不同哈希值

我对ruby​​的“散列”方法有疑问:http://apidock.com/ruby/v1_8_7_330/Hash/hash我用它来比较具有相同内容的两个不同对象,以发现数据库对象和具有相同属性的新元素之间的冲突。它显然已经工作了很长时间(超过一年),但突然在我的开发计算机上停止工作了。如果我在Rails控制台中尝试这样做:a={:a=>'a',:b=>'b'}b={:a=>'a',:b=>'b'}a.hashb.hash我在同一控制台中为a.hash和b.hash(-3820017043059270405)获得了相同的值。问题是,如果我换到另一个控制台,它会返回与第一个控制台不同的

ruby-on-rails - 如何(大量)减少 Rails 应用程序中的 SQL 查询数量?

在我的Rails应用程序中,我有users,它可以有许多invoices,而invoices又可以有许多payments。现在在dashboardView中,我想总结一个user曾经收到的所有payments,按年、季度或月。付款也分割为毛额、Netty和税额。user.rb:classUser:items).allpayments_with_invoice.select{|x|range.cover?x.date}.sum(&:"#{kind}_amount")endend发票.rb:classInvoicepayment.rb:classPaymentdashboards_cont

ruby - 为什么 Ruby splat 不适用于条件赋值中的数组强制?

虽然splat(*)构造通常被称为splat运算符,但很明显,与其他一元运算符(如否定运算符(!)相比,它是一个不同的野兽。)运算符。splat在赋值(=)中使用时,它自己可以正常工作(即不包含在括号中),但在与条件赋值(||=)一起使用时会产生错误。示例:a=*(1..3)#=>[1,2,3]b||=*(1..3)SyntaxError:(irb):65:syntaxerror,unexpected*我不是在寻找替代方法来做同样的事情,而是在寻找对Ruby内部结构有更好理解的人来解释为什么splat结构的这种用法在第一种情况下有效,但在第二种情况下无效。